<template>
	<view class="homeLayout pageBg">
		<view class="banner">
			<swiper indicator-dots indicator-color="rgba(255,255,255,0.5)" autoplay circular>
				<swiper-item v-for="item in pets.slice(0,3)">
					<image :src="item.url" mode="aspectFill"></image>
				</swiper-item>
			</swiper>
		</view>
		<view class="notice">
			<view class="left">
				<uni-icons type="sound-filled" size="30" color="#444"></uni-icons>
				<text class="text">公告</text>
			</view>
			<view class="center">
				<swiper vertical autoplay interval="1500" duration="300" circular>
					<swiper-item v-for="item in 4">文字内容文字内容文字内容文字内容文字内容文字内容</swiper-item>
				</swiper>
			</view>
			<view class="right">
				<uni-icons type="right" size="16" color="#444"></uni-icons>
			</view>
			
		</view>
		<view class="select">
			<common-title>
				<template #name>每日推荐</template>
				<template #custom>
					<view class="date">
						<uni-icons type="calendar" size="18"></uni-icons>
						<view class="text">
							<uni-dateformat :date="Date.now()" format="dd号"></uni-dateformat>
						</view>
					</view>
				</template>
			</common-title>
			<view class="content">
				<scroll-view scroll-x="true" >
					<view class="box" v-for="item in pets.slice(3,8)">
						<image :src="item.url" mode="aspectFill"></image>
					</view>
				</scroll-view>
			</view>
		</view>
		
		<view class="theme">
			<common-title>
				<template #name>专题精选</template>
				<template #custom>
					<navigator url="" class="more">More+</navigator>
				</template>				
			</common-title>
			<view class="content">
				<theme-item v-for="item in 8"></theme-item>
				<theme-item :isMore="true"></theme-item>
			</view>
		</view>
	</view>
</template>

<script setup>
import {ref,computed} from "vue"
import {onReachBottom, onPullDownRefresh} from "@dcloudio/uni-app"
const pets=ref([])
function network(){
	uni.showNavigationBarLoading()
	uni.request({
		url:"https://api.thecatapi.com/v1/images/search",
		data:{
			limit:10
		}	
	}).then(res=>{
		if (res.statusCode === 200){
			pets.value=[...pets.value, ...res.data]
		}
		else{
			uni.showToast({
				title:res.data,
				icon:"none",
				duration:2000
			})
		}
	}).catch(err=>{
		uni.showToast({
			title:"请求有误 ，请重新刷新",
			icon:"none",
			duration:2000
		})
	}).finally(()=>{
		uni.hideNavigationBarLoading()
		uni.stopPullDownRefresh()
	})
}
network()
onPullDownRefresh(()=>{
	pets.value=[]
	network()
})
</script>

<style lang="scss" scoped>
	.homeLayout{
		.banner{
			width: 750rpx;
			padding: 30rpx 0;
			swiper{
				width:750rpx;
				height:340rpx;
				&-item{
					width:100%;
					height:100%;
					padding:0 30rpx;
					image{
						width:100%;
						height:100%;
						border-radius: 30rpx;
					}
				}
			}
		}
		.notice{
			width:690rpx;
			height:80rpx;
			line-height: 80rpx;
			background: #e9e9e9;
			margin: 0 auto;
			border-radius: 80rpx;
			display: flex;
			.left{
				width:140rpx;
				display: flex;
				align-items: center;
				justify-content: center;
				.text{
					color:$uni-color-warning;
					font-weight: 600;
					font-size: 28rpx;
				}
			}
			.center{
				flex: 1;
				swiper{
					height:100%;
					&-item{
						height:100%;
						font-size:30rpx;
						color:#666;
						overflow: hidden;
						white-space: nowrap;
						text-overflow: ellipsis;
					}
				}
			}
			.right{
				width:70rpx;
			}
		}
		.select{
			padding-top: 50rpx;
			.content{
				width:720rpx;
				margin-left: 30rpx;
				margin-top: 30rpx;
				scroll-view{
					white-space: nowrap;
					.box{
						width: 200rpx;
						height: 430rpx;
						display: inline-block;
						margin-right: 15rpx;
						image{
							width: 100%;
							height:100%;
							border-radius: 10rpx;
							
						}
					}
					.box:last-child{
						margin-right: 30rpx;
					}
					
				}
			}
			.date{
				color:#28b389;
				display: flex;
				align-items: center;
				:deep(){
					.uni-icons{
						color:$brand-theme-color !important;
					}
				}
				.text{
					margin-left: 5rpx;
					
				}
			}
		}
		.theme{
			padding: 50rpx 0;
			.more{
				font-size: 32rpx;
				color:#888;
			}
			.content{
				margin-top: 30rpx;
				padding: 0 30rpx;
				display: grid;
				gap:15rpx;
				grid-template-columns: repeat(3, 1fr);
			}
		}
	}
</style>
